腾 入 式 linux 工程 师 和 面试 题目 CGC 语言 基础 部 分 


和 污 
Strnga 发 布 于 2008.5-23| 一 | 1059 次 阅读 “ 宣 号 : 大 中 小 (网友 评论 1 条 ) 我 亚 评论 


在 网 上 看 到 了 一 篇 钳 入 式 的 而 试题， 总 然 觉得 自己 很 融 小 .…… 在 未 来 一 段 时 间 内 我 会 陆续 贴 上 我 的 管 案 ， 当 然 可 能 有 些 我 做 不 出 来 ， 
居 出 来 的 也 不 一 定 蕉 确 ， 在 检验 和 提 丙 笑 己 的 同时 ， 和 希望 有 走 过 路 过 商人 指点 一 二 。 


下 人 面 的 题目 必须 全 部 知 对 才 络 分 : 

1、 到 何在 C 中 初始 化 一 个 字符 数组 . 

2、 如 何在 忆 中 为 一 个 数组 分 配 空间 . 

3、 训 何 初 冶 化 一 个 指针 数组 . 

4、 如 何 定 交 一 个 有 10 个 元 素 的 驻 数 型 指针 数组 。 

5、 S[10] 的 另外 一 种 表达 方式 是 什么 。 

6、 GCC3.2.2 版 本 中 支持 哪儿 种 网 程 语言 。 

7、 要 使 用 CHAR_BIT 沉 要 包含 娜 个 头 文件 : 

8、 对 (-1.2345) 取 整 是 多少 ? 

9、 刀 何 让 局 部 变量 具有 全 局 生命 期 。 

10、 CC 中 的 和 常量 尝 符咒 应 在 何 时 定义 ? 

11、 加 何在 两 个 .c 文件 中 引 内 对 方 的 变 基 。 

12、 使 用 malloc 之 前 需要 做 什么 玲 备 工 作 ， 

13、realloc 函数 在 使 用 上 要 注意 什么 问题 。 

14、strtok 函数 在 使 用 上 于 注意 什么 问题 。 

15、gets 函数 在 使 用 上 要 注意 什么 问题 。 

16、C 语言 的 词 兴 分 析 在 长 度 规 则 方面 末 用 的 是 什么 第 略 ? 
17、a+++++b 所 表示 的 是 什么 意思 ? 有 什么 问题 ? 

18、 刻 何 定义 Bool 变量 的 TRUE 和 FALSE 的 值 。 

19: CC 语言 的 const 的 售 义 是 什么 -。 在 定 站 常量 时 ， 为 什么 推荐 使 用 consti 而 不 是 #define。 
20、C 语言 的 volatile 的 售 义 是 什么 。 使 用 时 会 对 网 详 器 有 什么 暗示 。 


这 部 分 基 ANSI C 的 一 些 问 题 ， 题 目的 前 提 基 必须 者 答对 ， 看 己 很 变态 ， 但 是 细 想 一 下 ,， 这些 都 是 最 基础 的 ， 虽 然 我 们 在 使 用 他 们 的 时 
候 会 犯 这 样 那样 的 错 煤 ,但 荐 车 经 目的 其 不 犯错 误 ， 不 荐 从， 那 和 又 好 ， 从 最 基础 的 开始 。 


1、 划 何在 CC 中 初始 化 一 个 字符 数组 . 

这 个 问题 看 似 很 简单 ,但 基 我 们 要 将 最 简单 的 问题 用 最 严谨 的 态度 来 对 符 。 关键 的 地 方 : 初始 性 、 孚 符 型 、 数 组 。 报 简单 的 方法 是 char 
array;。 这 个 问题 看 似 和 解决 了 ， 但 是 在 韧 始 化 上 好 像 还 类 缺 点 什 各 ， 个 人 认为 : char array[5]= 234， 54; 或 者 char 
array[5]=f"12345"q; 或 者 char array[2][10]=f"China""Beijing" 也 许 更 符合 “初始 化 "的 意思 。 


2、 世 何 在 避 中 为 一 个 数组 分 配 衬 间 。 


最 简单 的 方法 是 : char array [5]: 意思 是 分 配给 数组 array 一 个 5 个 学 节 的 空间 。 但 是 我 们 要 知道 在 嫌 中 数组 其 实 就 是 一 个 名字， 其 实 
质 人 音义 就 是 指针 ， 比 如 char array[]， 是 到 底 分 配 的 莹 少 空间 ? 所 以 我 们 要 将 其 分 成 为 两 种 不 同 的 形式 给 出 答案 : 

一 种 是 栈 的 形式 : char array[5]; 

一 种 是 堆 的 形式 ，char *array; amay =(char *)malloc(5)//C++: array =new charl 本 |; 

堆 和 栈 的 会 六 其 实 我 也 没 弄 太 透 彻 ， 改 天 明白 了 再 发 一 篇 。 

我 们 要 明白 的 是 ,第 一 种 形式 空间 分 配 的 大 小 可 能 会 受 操作 系统 的 限制 ,比如 windows 会 限制 在 2M， 第 二 种 形式 成 空间 分 配 很 灵活 ， 
想 分 配 多 少 分 配 考 少 ， 上 内 要 RAM 够 大 ， 


3、 蔬 何 初 冶 化 一 个 指针 数组 . 

首先 明确 一 个 概 仿 ， 就 是 指 回 数组 的 指针 ， 和 存放 指针 的 数组 ， 

指 同 数组 的 指针 : char (*array )[5]; 合 头 是 一 个 指向 存放 5 个 尝 符 的 数组 的 指针 。 

和 仔 放 指 针 的 数组 : char "array [Sj]; 定义 其 一 个 数组 中 存放 了 5 个 指 同 子 符 型 数据 的 指针 

按照 题 意 ， 我 理解 为 初始 化 一 个 存放 指针 的 数组 ，char *array [=f"China","Beijing 中 :其 含义 是 初始 化 了 一 个 有 两 个 指向 字符 型 数据 的 
指针 的 数组 ， 这 两 个 指针 分 别 指 向 子 符 串 "China" 和 "Beijing"。 


4、 如 何 定义 一 个 有 10 个 元 素 的 整数 型 指针 数组 . 
既然 只 是 定义 而 不 是 梓 妈 化， 那 就 很 简单 且 没 有 争议 了 : int *array[10];。 


5、 Ss[10] 的 另外 一 种 表达 方式 是 什么 。 
前 而 说 过 了 了 ， 数 组 和 指针 其 实 蚌 数据 存在 形态 的 两 种 表现 形式 ,如果 说 对 于 数组 s]， 我 们 知道 *s=s[0], 那么 s[10] 的 另 一 种 表达 方式 就 
是 : “(s+10)。 


6、 GCC3.2.2 版 本 中 支持 哪儿 种 网 程 证 言 。 

这 个 问题 实在 变态 ， 就 像 问 你 和 rror 的 作用 基 什 么 一 样 。 不 可 和 理 试 ，gec 是 linux 下 一 个 部 点 ， 基 一 个 备 受 无 数 程 序 员 推 某 的 网 详 器 ， 
其 优点 省 略 1000 字 ， 有 兴趣 可 以 自己 查 , 我 和 了 和 蔓 书 ， 书 上 日 : 支持 C,C++,Java,Obj-C,Ada,Fortran,Pascal,Modula-3 等 语言 ， 这 个 
“等 "比较 要 俩 ， 不 过 我 认为 已 经 很 全 了 ， 加 玉 认 为 还 荐 不 全 , 干脆 把 ASM 也 加 上 算 了 ,不 过 那 已 经 不 算 基 织 详 了 。 


7、 要 使 用 CHAR_BIT 南 要 包含 哪个 水 艾 件 . 
旭 盯 结 合 上 而 的 问题 ， 答 暴 的 大 信 计 会 认为 自己 撞 抱 了 ， 这 个 问题 实在 基 .…... 搜 索 了 一 下 ， 应 该 是 limits.h。 


8、 对 (-1.2345) 取 整 是 名 少 ? 


其 实 不 同 的 到 整 函数 可 能 有 不 同 的 侍 未 ， 不 过 这 个 数 没 有 太太 的 争议 ， 答 党 是 -1- 


8、 世 何 让 局 部 变 基 具有 全 局 生命 期 。 
其 体 的 生 市 期 的 概念 我 秒 得 我 还 要 好 好 这 入 的 学 习 一 下 , 但 是 这 个 题目 还 得 比较 简单 , 即 用 static 修饰 就 可 以 了 , 但 是 只 是 生 市 期 延长 ， 
范围 并 没有 扩大 ， 除非 把 这 个 变 且 定义 在 函数 体外 的 静态 区 ， 不 过 那样 就 变 成 全 局 变 若 了， 仿佛 不 符 疗 题 目 要 求 。 


10、 忆 中 的 常 基 学 符 囊 应 在 何 时 定 头 ? 
这 个 问题 说 实话 不 是 很 理解 电 干 的 蕊 思 ， 据 我 埋 佣 ， 有 两 各 情况 ， 一 种 十 预 处 理 阶段 ， 败 #define 定义 ; 还 有 就 是 使 用 const 企 饰 词 ， 
不 过 const 修饰 的 基 一 个 变 世 ， 其 什 义 是 "只 读 "， 称 之 为 浓 量 并 不 谁 确 ， 但 基 确 实 可 以 用 操作 变量 的 方 尘 当 弟 量 用 。 所 以 还 蚌 第 一 种 比 


较 午 谱 。 


11、 如 何在 两 个 .c 艾 件 中 引用 对 方 的 变量 。 

这 个 问题 也 问 的 禾 含 糊 的 ， 怎 么 说 呢 ， 基 简单 最 直接 的 方法 是 为 要 量 语 加 extem 履 饰 间 ， 当 然 ， 这 个 变 景 必 痢 基 全 局 变 其 。 还 有 一 种 
就 是 利用 档 数 调 用 来 进行 变量 的 闻 接 引 几 ， 比 如 这 个 文件 中 的 一 个 函数 引用 为 外 一 个 它 中 的 函数 ,将 变量 通过 实 参 的 形式 传递 过 去 
不 过 题目 既然 说 是 引用 ， 那 么 还 是 用 第 一 个 各 深 好 了 。 


12、 使 用 malloc 之 前 表 要 做 什么 准备 工作 。 

其 实 淮 备 工 作息 党 啊 ， 比 媚 你 家 要 一 台 计 算 机 之 类 的 :玩赏 语 ， 我 们 首先 要 乔 道 malloc 的 用 途 ， 简单 的 说 就 是 动态 的 分 配 一 段 空间 ， 
瓜 回 这 段 至 间 的 头 指 针 >。 实际 的 准备 工作 可 以 这 各 分 : 冤 要 过 段 空间 的 指针 基 否 存在 : 若 不 存在 ， 则 定义 一 个 措 针 用 来 被 赋值 ， 还 要 
清楚 要 退回 一 个 逢 么 类 型 的 指针 ， 分 配 的 空间 是 和 理 合 理 ; 如 来 指 儿 己 经 在 在 ， 屠 各 在 有 竺 独 将 新 的 空 问 尖 地 址 赋值 绍 这 个 指针 之 前 ,要 
完 判 断 指 针 基 否 为 NULL， 如 来 不 其 要 free 一 下 ， 否则 原来 的 焉 辣 就 会 被 洪 费 ,或 者 出 销 ，free 之 后 就 按照 前 一 种 情形 考虑 就 可 以 了 。 


13、realloc 函数 在 使 用 上 要 注意 什么 问题 。 

这 个 函数 我 也 和 才 知 道 的 ,证 一 个 。 据 我 的 韧 步 理 解 ， 这 个 函 束 的 作用 是 重新 分 配 宅 间 大 小 ， 有 返回 的 头 指 针 不 变 ， 只 基 民 变 空 间 大 小 。 
既然 是 改变 ， 就 有 变 大 、 变 小 和 为 什么 改变 的 问题 。 变 大 ， 要 证 意 不 能 天 到 内 存 遵 出: 变 小 ， 那 变 小 的 那 部 分 空间 会 被 征用 ， 原 有 数 
据 不 再 存在 ; 为 什么 改变 ， 如 果 是 想 重 新 邱 作 他 用 ， 还 是 先 free 了 吧 。 


14、strtok 函数 在 使 用 上 要 注意 秆 么 问题 
这 个 问题 我 不 知道 能 不 能 回答 全 而 ， 因 为 实在 是 财 的 很 少 。 这 个 函数 的 作 几 是 分 割 宇 符 囊 ， 但 其 要 分 嘎 的 字符 串 不 能 是 常量 ， 这 是 要 
注意 的 。 比 如 先 定 哆 一 个 学 符 串 :char array[]="part1,part2" ，strtok 的 原形 是 char *strtok(char *string, char *delim);， 我 们 将 "" 作 为 


分 曾 符 ， 先 用 pt=strtok(array,"");， 得 到 的 结果 print 出 来 就 是 "part{"， 那 后 面 的 呢 ， 要 写成 pt=strtok(NULL,"， 广 意 ， 杰 用 NULL， 


如 果 被 分 制 的 字符 串 会 被 分 成 M 段 ， 那 从 第 二 次 开始 就 一 直 要 用 NULL- 总 竺 起 来 ， 需 要 注意 的 是 : 被 和 益 荐 的 字符 串 和 分 隔 符 都 要 使 
用 变量 ， 除 第 一 总 使 用 指 回 宇 特 串 的 指针 外 ， 之 后 的 者 要 使 用 MULL:， 注意 使 用 这 个 函数 的 时 候 千 万 别 把 指针 中 斑 了 ， 环 然 就 企 乱 了 -。 


15、gets 函数 在 使 用 上 要 注意 什么 问题 。 

这 是 一 个 键盘 输入 函数 ， 将 输入 学 符 串 的 涉 地 址 返回 。 说 到 要 注意 的 问题 ， 我 还 是 党 家 了 一 下 网 上 的 一 些 情 视 ， 光 要 注意 的 就 是 gets 
以 输入 回 车 结 东 ， 这 个 地 球 人 都 知道 ， 但 是 很 多 人 不 知道 的 是 ， 当 你 输入 完 一 个 学 符 串 后 ， 这 个 字符 串 可 能 依然 存在 于 这 个 标准 输入 
流 之 中 ， 当 再 冤 使 用 gets 的 时 候 ， 也 许 会 把 上 次 输入 的 东西 读 出 来 ， 所 以 应该 在 使 用 之 后 用 flushfstdin) 处 理 一 下 ， 将 输入 流 清 空 。 

基 后 也 还 是 要 广 意 流出 的 问题 。 关于 这 个 党 染 我 比较 合 糊 ， 不 知道 有 没有 商人 两 见 ? 


16、C 语言 的 词 然 分 析 在 长 度 规 则 方面 采用 的 是 什么 党 覆 ? 

我 无 请 ...... 闻 所 未 闻 啊 ..….. 还 是 搜索 了 一 下 ， 有 一 篇 文章 ， 地 址 是 ，http://202.117.80.9/jp2005/20/kcwziwlkchwlkc/03/3 5 2.htm， 是 
共 于 词法 分 析 骂 的 。 其 中 提 到 了 两 点 第 略 : (1) 按 最 长 匹配 原则 确定 被 选 的 词 型 : (2) 如 果 一 个 学 符 串 能 为 若干 个 词 型 匹配 ， 则 排列 在 
起 前 而 的 词 型 被 选中 。 不 庆 道 是 不 是 盟 干 的 要 求 ， 还 蚌 其 他 什么 。 我 及 一 介 草 民 ， 望 达 人 指点 玉 津 1 


17、a+++++ 上 历 表 示 的 是 什么 意思 ? 有 人 征 么 问题 ? 

这 个 东西 【 称 之 为 东西 一 点 都 不 过 分 ) 其 实 并 没有 语法 销 误 ， 按 照 C 对 运算 符 等 级 的 划分 ，++ 的 优先 仍 大 于 +， 那 么 这 句 话 会 被 纲 评 
器 看 司 : (at++)t(++b)， 这 回 明 白 了 吧 。 有 什么 问题 ， 语 法 上 没有 问题 ， 有 的 是 道 短 上 的 问题 ! 作为 一 个 优秀 的 程序 员 ， 我 们 村 力求 证 
句 的 全 证 性 和 可 读 性 ， 训 来 写 这 全 的 人 是 在 一 个 team 里 ， 那 么 他 基本 会 被 打 的 半死 .…... 最 后 讨论 一 下 结果 : 侦 设 a 之 前 的 值 基 3, b 
是 4， 那 么 运行 完 这 个 变态 语句 后 ， 引 的 值 是 4，b 是 5， 语 句 的 时 果 是 8- 


18、 划 何 定义 Bool 变量 的 TRUE 和 FALSE 的 值 。 

不 知道 这 个 题 有 秆 么 隐 阱 ， 写 到 项 在 神经 已 经 大 了 ， 一 般 来 说 先 要 把 TURE 和 FALSE 给 定义 了 了， 使 用 #define 就 可 以 : 
#define TURE 1 

#define FALSE 0 


如 果 有 一 个 变量 禹 要 定 饼 成 bool 型 的 ， 举 个 例子 ，bool a=TURE; 就 可 以 了 。 


19、 CC 语言 的 const 的 富 义 是 什 竺 。 在 定义 常量 时 ， 为 什么 推荐 使 用 const， 而 不 是 #define。 

首 洁 ， 这 个 题 干 抽 了 10 冲 回答 的 一 个 大 嘴巴 。 关 于 汕 量 的 概念 看 来 我 归 好 好 看 看 书 了 .…….. 我 说 过 了 ，const 修饰 词 可 以 将 一 个 变量 懂 
饰 为 "只 读 "， 这 个 就 能 称 为 常量 各? 姑且 认为 可 以 。 回 到 题目 中 ，const 基 只 读 的 意思 ， 它 限定 一 个 变量 不 人 允许 被 改变 ， 谁 都 不 能 故 ! 
既然 是 懂 饰 变 是 ， 那 双 变 量 的 类 型 就 可 以 丰富 多 彩 ，int 啊 ，char 啊 ,只 要 C 认识 的 都 可 以 : 但 基 间 efine 就 不 可 以 了 ;在 预 处 理 阶 段 
缺 达 类 型 粒 制 机 制 ， 有 可 能 会 出 销 。 还 有 就 是 变 芋 可 以 extem， 但 是 #define 惑 不 可 以 。 豫 亿 const 还 可 以 节省 RAM， 这 个 我 倒是 设 有 
考证 过 。 至 于 const 的 用 法 和 和 作用， 有 很 多 ， 我 会 总 络 后 发 上 来 。 


20、C 语言 的 volatile 的 会 久 基 慎 笃 。 司 用 时 会 对 出 详 器 有 什么 暗示 。 

此 于 最 后 一 题 了 ， 窖 易 么 .如果 这 个 测试 是 一 个 关于 嵌入 式 的 ， 那 么 这 道 题 非常 重要 ! ! 从 词 而 上 讲 ，volatile 的 意思 是 易 变 的 ， 也 
就 是 说 ， 在 程序 运行 过 程 由 ， 有 一 些 变量 可 能 会 被 莫名 其 录 的 改变 ， 而 优化 器 为 了 节约 时 间 ， 有 上 时候 不 会 重读 这 个 变量 的 真实 值 ， 而 
是 去 读 在 寄存 只 的 备份 ， 这 样 的 话 ， 这 个 变量 的 真实 值 反而 被 优化 器 给 “优化 " 掉 了 ， 用 时 怒 的 词 说 就 是 被 “和谐 "了 。 如果 使 用 了 这 个 修 
饰 词 ， 就 是 通知 网 详 顺 别 犯 司 ， 老 老实 实 去 重新 读 一 遍 ! 可 能 我 说 的 太 “ 道 伦 "了 ， 那 么 我 引用 一 下 “大 师 "的 标准 解释 : 

volatile 的 本 意 是 " 易 变 的 ”。 

由 于 访问 寄存 器 的 速度 要 快 过 RRAM, 所 以 织 详 器 一 般 都 会 作 减 少 存 取 外 部 RAM 的 优化 ， 但 有 可 能 会 读 胜 数据 。 当 要 求 使 用 volatile 声 
明 的 变量 的 值 的 上 时候， 系统 总 基 重 新 从 它 所 在 的 内 存 读 取 数 据 ， 妈 使 它 前 而 的 指令 刚刚 从 读 处 读 了 到 过 数据 。 而 且 读 取 的 数据 并 刻 被 保 
存 。 

精确 地 说 就 是 ， 优 履 融 在 用 到 这 个 变 基 时 必须 每 次 都 小 心地 重新 读 取 这 个 变量 的 值 ， 而 不 基 使 用 保存 在 寄存 损 里 的 备份 。 

下 击 是 volatile 变量 的 几 个 例子 ， 

1). 并 行 设备 的 健 件 寄存 大 如 状 意 罕 企 内 ) 

2). 一 个 中 断 服务 子 程序 中 会 访问 到 的 非 自动 变量 {Non-automatic variables) 

3)、， 多 线程 应用 中 被 几 个 任务 共享 的 变量 

座 入 式 系统 程序 员 经 常 同 硬件 、 中 断 、RTOS 等 等 打交道 ， 所 用 这 些 都 要 求 volatile 变量 。 不 懂得 volatile 内 容 将 会 带 来 灾难 。 


好 了 ， 和 营 完 了， 也 不 知道 标准 答案 是 什么 。 如 朱 有 达 人 看 到 争 己 法 的 语 ， 于 万 停 下 来 ， 良 费 您 宝 真 的 几 分 钟 时 间 指 点 一 二 ， 不 胜 感激 ! 


